#include <iostream>

using namespace std;

const int N = 50;

int n, m;
int f[N][N]; // f[i][j]:表示传递 i次后,落在第j号同学的次数

int main()
{
	cin >> n >> m;

	f[0][1] = 1;
	for (int i = 1; i <= m; i++)
	{
		// 处理第一个同学
		f[i][1] = f[i - 1][2] + f[i - 1][n];

		// 处理中间同学
		for (int j = 2; j < n; j++)
		{
			f[i][j] = f[i - 1][j - 1] + f[i - 1][j + 1];
		}
		
		// 处理最后一位同学
		f[i][n] = f[i - 1][1] + f[i - 1][n - 1];
	}

	cout << f[m][1] << endl;

	return 0;
}